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CONJUGATE FLOW PROCESSOR 



Eidd 



The present invention relates generally to microprocessors, and more 
specifically to microprocessors that support dynamic optimization of software. 



Background of the In ve ntion 

10 

Modem microprocessors and software compilers employ many techniques to 
help increase the speed with which software executes. Examples of techniques that 
are used to help speed up the execution speed of processors include speculative 
execution of code, reuse buffers that hold instances of previously executed software 
15 for later reuse, and branch target buffers (BTB) that try to predict whether branches 
are taken. 

Research is ongoing in areas of modeUng processor performance. See Derek 
B. Noonburg & John P. Shen, "Theoretical Modeling of Superscalar Processor 
performance," MICRO-27, November 1994; and Derek B. Noonburg & John P. 

20 Shen, "A Framework for Statistical Modeling of Superscalar Processor 
Performance," Proceedings of the Third International Symposium on High 
Performance Computer Architecture, February 1997. 

Some modem processors employ dynamic optimization that attempt to more 
fixUy utilize the resources of the processor. Approaches include: control speculation 

25 using predicate promotion; load speculation using advanced or speculative advanced 
load or prefetch load; and static hints for branch direction or cache placement for 
loads. Many of these approaches can result in "non-essential" code used for 
optimization being intermixed with "essential" application level software code. 
The essential code is typically created by a compiler from the application 

30 level software code. The essential code is what determines the logical correctness of 
the resulting program. The non-essential code is also typically created by a compiler, 



but it differs from the essential code in that it is a result of optimizations and other 
compile-time operations, rather than the applications level software program. 

Intermixing of non-essential code and essential code creates competition for 
processor resources between the two types of code. Although a net increase in 
5 execution speed can result from the above techniques, if the competition for 
resources is fierce, the above techniques can slow down the execution of the 
application level software. 

In addition to static intermixing of non-essential code with essential code, 
some known dynamic optimization techniques reorder machine instructions in an 

10 attempt to more fiiUy utilize processor resources. For example, dynamic optimizers 
can introduce non-essential prefetch instructions and intermix them with original 
essential code, and/or reorder the original essential code based on run-time dynamic 
profiling feedback. This can lead to problems, in part because reordering of machine 
instructions may draw out latent "bugs" in the software, thereby sacrificing the 

1 5 logical correctness of the application level software code. One example of a latent 
bug is an uninitialized variable. The bug may not be detected in the original code 
because of a fortuitous register assignment, but wKen instructions are reordered, the 
bug may manifest itself. 

For the reasons stated above, and for other reasons stated below which will 

20 become apparent to those skilled in the art upon reading and understanding the 

present specification, there is a need in the art for an alternate method and apparatus 
for combining essential code and non-essential code. 

Brief Description of the Drawings 

25 

Figure 1 shows a conjugate processor; 
Figure 2 shows a conjugate mapping table; 

Figure 3 is a diagram showing the generation of a runtime binary with h- 
flow; and 

30 Figure 4 shows a processing system. 
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5 In the following detailed description of the embodiments, reference is made 

to the accompanying drawings that show, by way of illustration, specific 
embodiments in which the invention may be practiced. In the drawings, like 
numerals describe substantially similar components throughout the several views. 
These embodiments are described in sufficient detail to enable those skilled in the art 

1 0 to practice the invention. Other embodiments may be utilized and structural, logical, 
and electrical changes may be made without departing from the scope of the present 
invention. Moreover, it is to be understood that the various embodiments of the 
invention, although different, are not necessarily mutually exclusive. For example, a 
particular feature, structure, or characteristic described in one embodiment may be 

15 included within other embodiments. The following detailed description is, therefore, 
not to be taken in a limiting sense, and the scope of the present invention is defined 
only by the appended claims, along with the full scope of equivalents to which such 
claims are entitled. 

The method and apparatus of the present invention provide a mechanism for 
20 executing essential code and non-essential code in separate pipelines, A first 

pipehne executes the essential code which determines the logical correctness of the 
application level software. A second pipeline executes the non-essential code, A 
conjugate mapping table maps triggers that include instruction attributes, data 
attributes, event attributes, and state attributes to portions of the non-essential code . 
25 When a trigger is "satisfied," the non-essential code mapped thereto is executed in 
the second pipeline. In some embodiments, the non-essential code provides hints to 
increase efficiency of the operation of the first pipeline. In other embodiments, the 
non-essential code virtualizes instructions or groups of instructions in the essential 
code. 
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In this description essential and non-essential code are defined with respect to 
a particular reference architecture. Essential code is that code which is both 
necessary and sufficient for correct execution of a program on the reference 
architecture. Non-essential code is code which is not necessary for correct execution, 
5 but which may benefit the performance of the essential code on the reference 
architecture. In a pure implementation of the reference architecture, all essential 
code is executed on a visible main pipeUne, while all non-essential code is executed 
on a second intemal pipeline, which may be optionally omitted with no impact on 
correctness of the executed program. In some embodiments that deviate from the 
10 reference~architecture, the visible main pipeline does not execute all of the essential 
code. In these embodiments, some essential code is executed on a second intemal 
pipeline along with any non-essential code. 

A typical example occurs when a first reference architecture is implemented 
as described, including the optional intemal pipeHne. A subsequent reference 
1 5 architecture is then defined with functionality which is a proper superset of the first 
reference architecture. Using the optional intemal pipeline, through mechanisms to 
be described, the origmal implemented architecture is then able to support the 
enhanced functionality of the subsequent reference architecture. The portion of 
essential code that uses the added functionality of the second reference architecture 
20 cannot be executed on the visible main pipeline of the implemented architecture, and 
so is executed with any nonessential code on the intemal pipeline instead. 

Figure 1 shows a conjugate processor according to an embodiment of the 
present invention. Conjugate processor 100 includes instruction set architecture 
(ISA) visible path 102, microarchitectural structures 1 12, conjugate mapping table 
25 200, h-flow cache 122, h-flow pipehne 120, and dynamic code analysis block 124. 
"H-flow" is a term that describes a "hint calculus" instruction flow that is separate 
from the main instruction flow in main pipehne 106 within ISA visible path 102. 
"Hint calculus" is a term that describes the action of h-flow pipeline 120 as it 
generates "hints" and communicates them to microarchitectural states 1 12. Hint 
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calculus is, by definition, non-essential code. In other words, hint calculus does not 
affect the logical correctness of the application level software. 

ISA visible path 102 includes main pipeline 106 and structures associated 
therewith. Structures within ISA visible path 102 are visible to the applications level 
5 programmer, hence the term "ISA visible." Icache 104 receives instructions on node 
108, and provides instructions to main pipeline 106 on node 1 10. Main pipeline 106 
includes pipeline stages such as decoding, executing, and committing. In general 
ISA visible path 102, and main pipeline 106 in particular, execute essential code. 
Icache 104 and h-flow cache 122 are logically separate cache memories. 

1 0 Each holds instructions from different instruction streams. Icache 1 04 holds 

essential instructions and h-flow cache 122 holds non-essential instructions. In some 
embodiments, the physical design of the cache combines Icache 104 and h-flow 
cache 122. In these embodiments, an instruction fetched into h-flow cache 122 is 
available in Icache 104 to be fetched by main pipeline 106. In some embodiments, 

1 5 this feature is exploited for instruction prefetch purposes by using h-flow pipeline 
120 to prefetch essential instructions that are expected to be executed by main 
pipeline 106. 

Main pipeKne 106 communicates with microarchitectural structures 1 12. 
Microarchitectural structures 1 12 include structures that store the microarchitectural 

20 states of the processor. Examples include register banks, branch target buffers 
(BTBs), data cache, and reuse buffers. Main pipeline 106 can retrieve state 
infoimation from microarchitectural structures 1 12, and can also modify state 
information held in microarchitectural structures 1 12. 

The terms "architectural structures" and "architectural states" are used herein 

25 to describe the processor at a level that is visible to a programmer. For example, 
structures included within ISA visible path such as an architectural register file in 
main pipeline 106 are architectural structures. In contrast, the terms 
"microarchitectural structures" and "microarchitectural states" are used herein to 
refer to low level logical structures within the processor that are not necessarily 

30 visible to a programmer. For example, conjugate processor 100 includes 
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microarchitectural structures 1 12 that are not within ISA visible path 102, but that 
can influence architectural states of main pipeline 106 using communications on 
node 114, In some embodiments, the architecture is implemented using the 
microarchitecture, and the architectural states are a subset of the microarchitectural 
5 states* 

Conjugate mapping table 200 receives instructions on node 108 and state 
information on node 126. The state information on node 126 can be 
microarchitectural or architectural state information. In some embodiments, 
conjugate mapping table 200 includes triggers and targets. When triggers are 

10 satisfied, then the target is communicated to h-flow cache 122, which in turn 

provides instructions from h-flow memory or cache structures that include h-flow 
code (not shown) to h-flow pipeline 120. Conjugate mapping table 200 is explained 
more fully with reference to Figure 2 below. H-flow cache 122 can include actual h- 
flow code sequences, sometimes referred to as "handlers," or can include pointers to 

15 the handlers. H-flow cache 122 can also include pointers to data that is used by h- 
flow code. 

In the reference architecture, h-flow is a conjugate flow that represents the 
logical conjugate of the normal instruction flow of the processor. The normal flow 
of the processor executes instructions that provide the logical correctness of the 

20 program. For example, instructions compiled from a user's program are executed in 
main pipeline 106, and this execution modifies the architectural state of processor 
100 in the manner intended by the user. This is the essential code, or the code that 
ensures the architectural state is modified in the manner intended by the user. The 
code is called "essential" because it is what determines the final architectural state of 

25 the processor, 

H-flow code, in contrast, is "non-essential" code. It is referred to as non- 
essential because in some embodiments, it does not directly affect architectural states 
of processor 100, even though it may affect microarchitectural states of the 
processor. H-flow encodes or computes hints that can potentially lead to improved 

30 efficiency in computation of the essential code in main pipeline 106. 
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As shown in Figure 1, h-flow pipeline 120 communicates with 
microarchitectural structures 1 12 on node 116. H-flow pipeline 120 can retrieve 
architectural or microarchitectural states on node 116, and can also modify 
microarchitectural states held in microarchitectural structures 112. In some 
5 embodiments, h-flow code executed in h-flow pipehne 120 can also directly affect 
architectural states of conjugate processor 100. 

Instructions defined for execution by h-flow pipeline 120 include instructions 
to handle state transfer and resource mapping between states of main pipeline 106 
and states of h-flow pipeline 120, Examples include instructions to download states 
10 from the main pipeline's registers to the h-flow pipeline's registers, and instructions 
to upload states from the h-flow pipehne's register to the main pipeline's registers. 

Conjugate flow processor 100 provides a general schema to express a flexible 
association of diverse hints with the essential portion of the code at various 
granularities of instructions. This is provided through conjugate mapping table 200, 
15 which is described more fully with reference to Figure 2 below. Because the non- 
essential portion of the code is not intermixed with the essential portion, conjugate 
processor 100 can support dynamic computation of hint calculus for any aspect of the 
microarchitectural optimization without impacting the organization of the essential 
code. 

20 Dynamic code analysis block 124 analyzes the execution of code in main 

pipeline 106 and generates h-flow code. The generated h-flow code, when executed, 
provides hints to ISA visible path 102 in an attempt to improve executioQ behavior. 
For example, if a branch is usually taken under certain conditions, dynamic code 
analysis block 124 can generate h-flow code to support speculative execution of the 

25 taken branch under the conditions discovered. 

In some embodiments, dynamic code analysis generates h-flow code and 
replaces default h-flow code that was created at compile time. For example, in the 
case of a web browser capable of accepting "plug-ins," optimum h-flow code for a 
plug-in cannot be generated at compile time for the web browser. When a plug-in is 

30 installed in the web browser, the dynamic code analysis can adaptively modify the h- 
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flow code utilized with the plug in. The h-flow code can be saved in a ".hint" section 
so that the next time the plug-in is executed, the h-flow code that is loaded is the h- 
flow code generated for the plug-in. The .hint section is a section of an executable 
file, much like a .text, .bss, or .data section, and can be saved with the .hint section 
5 for the web browser, or can be saved separately and dynamically linked when the 
web browser uses the plug-in. These mechanisms are explained more fully with 
reference to Figure 3 below. 

In some embodiments, dynamic code analysis block 124 creates directed 
acyclic graph (DAG) trace representations of code executed in main pipeline 106. 

10 The use of DAG traces in creating h-flow code is analogous to the ordering logic in 
an instruction scheduler. The instruction scheduler produces a DAG trace that 
identifies branch instructions that are either mostly taken or not taken. Dynamic 
code analysis block 124 captures the instruction DAG trace so that the next time the 
instruction is encountered, the previously generated DAG trace can be used. This 

15 can be beneficial when compared to instruction schedulers that regenerate the DAG 
trace every time a branch instruction is encountered. In traditional trace cache 
implementations, a trace represents a sequence of instructions executed in a 
particular program order, and does not include information describing inter- 
instruction data dependencies. In contrast, a DAG trace in a DAG trace cache of the 

20 present invention represents a sequence of instructions that are data dependent in 
program order. 

Dynamic analysis block 124 is also useful to alleviate problems associated 
with cache misses for load instructions. For a load instruction on the critical path of 
a program (meaning many future operations are data dependent on the load 

25 instruction) that frequently incurs cache misses, a DAG trace can be created that 
speculatively computes the memory access address for this load instruction. By 
running this DAG trace ahead of the flow in the main pipeline, the h-flow early run- 
ahead computation becomes essentially an "early probe for cache access prefetch." 
Long before the instruction that uses a load is executed, the load is initiated. The h- 

30 flow code includes instructions to determine the load address, and the load can be 
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performed as a prefetch by the h-flow pipehne. The data is loaded into data cache, 
and then the main pipehne can later access the data without causing a cache miss. 

It is not necessary for conjugate processor 100 to include dynamic code 
analysis block 124, Although dynamic code analysis block 124 provides a flexible 
5 mechanism for adaptively generating h-flow code, it is not the only mechanism to 
generate h-flow code. H-flow code can be statically generated, or can be 
dynamically linked from other sources. This is explained more fully with reference 
to Figure 3 below. 

Because conjugate processor 100 allows parallelism between the computation 

10 of the essential code and the computation of non-essential hint calculus code, httle 
resource competition exists between the two flows. 

H-flow code has many uses. Examples include sandbox checking, security 
checking, and instruction set virtualization at varying levels of abstraction. The 
remainder of this description discusses embodiments of conjugate processors and 

1 5 related mechanisms. Any of the embodiments described can be utilized for any 
purpose to which an h-flow code sequence can be put. For example, the discussion 
below with reference to Figure 2 describes various embodiments of triggers that can 
be used to trigger h-flow code sequences. Any of these triggers can be used to 
trigger h-flow code for any purpose. Also for example, if a particular embodiment is 

20 described with reference to h-flow code that adds security, it may also be the case 
that an h-flow code sequence supporting aggressive speculation can be substituted 
therefor without departing from the scope of the present invention. 

Figure 2 shows a conjugate mapping table. Conjugate mapping table 200 is a 
hardware table that implements conjugate mapping between triggers 212 and targets 

25 214. Conjugate mapping table 200 includes records 210, or "entries," that each map 
a trigger to a target. Triggers are conditions that can be satisfied, and targets are 
references to h-flow code sequences 220. When a trigger in a record is satisfied, h- 
flow code specified by the target is triggered. As a result, the h-flow code is 
executed in the h-flow pipeline. 
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Triggers included within conjugate mapping table 200 can include any 
information useful to trigger the execution of an h-flow code sequence. Examples 
include instruction triggers, data triggers, state triggers, and event triggers. 
Instruction triggers can trigger an h-flow code sequence based on an instruction 
5 attributes such as address, opcode, operand, and the like. Data triggers can include 
data attributes such as data operand values, data locations (including memory 
locations and register IDs), and the like. State triggers include architectural and 
microarchitectural state information such as the state of microarchitectural structures 
that influence speculative execution, code reuse, and the like. Event triggers can 
1 0 include aity event that occurs when software is executing. Examples of events 
include processor interrupts and exceptions. 

Trigger 202 is shown as an exploded view of one of triggers 212 in conjugate 
mapping table 200. Trigger 202 is a "vector" trigger made up multiple "atomic" 
attributes 204, 206, and 208. In general, triggers 212 can include single atomic 
1 5 attributes, or can include vector triggers. When a trigger is specified as a vector, as 
in the example of trigger 202, the trigger is satisfied when a boolean function of the 
atomic values is satisfied. For example, in an embodiment where atomic value 204 
includes an instruction location, atomic value 206 includes an instruction opcode, 
and atomic value 208 includes an instruction operand, and the boolean function is 
20 "and," trigger 202 is satisfied when the specified opcode and operand are fetched 
from the specified location. Atomic triggers can be negated, and by Usting several 
vector triggers with the same target, a nearly arbitrary sum-of-product expression can 
be generated. For example, two vector triggers with the same target can be used to 
generate the logical function: "trigger h-flow A execution if (1) the instruction 
25 pointer is X and register R is not zero, or (2) the instruction pointer is Y and the 
translation look-ahead buffer (TLB) is full. In some embodiments, Nth occurrence 
triggers are implemented. For example, an Nth occurrence trigger can implement the 
logical ftmction: "trigger h-flow A execution if N BTB misses are observed." 

In some embodiments, targets within conjugate mapping table 200 represent 
30 code and data. In other embodiments, targets within conjugate mapping table point 
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only to h-code sequences. The h-code sequences can have code sections and data 
sections such as ".text" section 222 and ".data" section 224 that are generated by a 
compiler. Within the data section, an h-flow sequence can save state information. 
For example, an h-flow sequence may be used to gather runtime profile information 
5 later used to gather reuse instances for reusable blocks of essential code. This profile 
information can be saved in the data section. 



Instruction Trig gers 
Instruction triggers can specify conditions based on one or more instruction 
10 attributes. These attributes include instruction locations (sometimes referred to as 
"instruction pointer values"), instruction opcodes, instruction operands, or the hke. 
When one of these attributes is used alone, it is an atomic trigger. An atomic trigger 
is satisfied when the condition specified by the single attribute is satisfied. For 
example, if an atomic trigger specifies an instruction pointer value, the trigger is 
1 5 satisfied when the instruction pointer value is encountered in the program, and the fa- 
flow code specified in the target of the corresponding record is triggered as a result. 

When an instruction opcode is mapped as an atomic trigger to an h-flow code 
sequence, the trigger is satisfied and the h-flow code sequence is executed when the 
opcode is encountered in the instruction stream. Likewise, when an instruction 
20 operand is mapped as an atomic trigger to an h-flow code sequence, the trigger is 
satisfied when the operand is encountered in the instruction stream. 

Instruction attributes can be utihzed separately as atomic triggers, or they can 
be used in combination as vector triggers. For example, when an opcode and 
operand are utilized together to create a vector trigger, the trigger is satisfied when an 
25 instruction is encountered having both the opcode and the operand. This allows 
more discrimination in the triggering of h-flow code sequences. 

Example uses for triggers based on instruction attributes include speculative 
execution and computation reuse. For example, if a fi*equently encountered block of 
essential code can be reused, meaning for the same set of input values (livein states), 
30 the code block produces the same set of output values (liveout states), the instruction 
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pointer marking the entrance to the reused block becomes a trigger entered in 
conjugate mapping table 200 and an h-flow code sequence implements the detection 
and verification of the reusability function in the h-flow pipeline to check whether 
there is a match of livein states. Likewise, if a particular branch within a program is 
5 often taken, an instruction pointer value that precedes the branch can be used as a 
trigger to cause speculative execution of the code in the taken branch. The results of 
speculative execution in the h-flow pipeline can be used in multiple ways. For 
example, the states of the h-flow pipeline that result from speculative execution can 
be copied to the main pipeline, or the actions of the h-flow pipeline can cause the 

10 instructions in the taken path to be fetched into instruction cache so that when the 
main pipeline takes the branch, the instructions are in instruction cache memory and 
can be fetched with low latency. 

An example use of an instruction operand in a trigger includes the re- 
mapping of virtual register sets. In some embodiments, a memory address or register 

15 ID can be specified as a trigger. When the location or register is accessed, the trigger 
is satisfied, and the corresponding h-flow code sequence is executed in the h-flow 
pipeline. If, in one generation of microprocessors, 128 registers exist, and in a later 
generation 256 exist, software compiled for the later generation may reference a 
register number higher than 128, When this code executes on the earher generation 

20 processor, conjugate mapping table 200 can have triggers that include a register 
address greater than 128. The trigger can cause h-flow code to perform a virtual 
mapping of registers such that software can run that attempts to access a greater 
number of registers than physically exist in a processor. In this manner, a bank of 
registers can be renamed or re-mapped using h-flow code sequences. 

25 Like the alternative register mapping described above, when a memory 

location is used as an instruction operand atomic trigger in conjugate mapping table 
200, alternative mappings for memory can be utilized. For example, a translation 
look ahead buffer (TLB) can be accessed with h-flow code. In this manner, an 
operating system can construct its own paging mechanism to manage a TLB 
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manipulated by h-flow code. This effectively allows an operating system to 

virtualize existing hardware normally built into the processor. 

Another example use of instruction attributes as triggers involves error 

checking. For example, an h-flow code sequence that performs an error checking 
5 routine can be triggered using an instruction operand as an atomic trigger. In this 

manner, certain registers, memory locations, or groups thereof, can be selectively 

subjected to error detection using h-flow. 

Instruction attributes as atomic triggers allow interception of code in the main 

pipeline at the instruction level. The contents of the atomic trigger specify an 
10 attribute of an instruction that is used for interception purposes. For example, when 

the atomic trigger is an instruction pointer, the instruction at that address triggers an 

h-flow sequence. Likewise, when the atomic trigger is an opcode, instructions 

represented by the opcode trigger an h-flow sequence. In the preceding paragraphs, 

atomic triggers have been described with reference to a few examples; however, any 
1 5 type of instruction attribute can be utilized as an atomic trigger without departing 

from the scope of the present invention. 

Data Triggers 

Data triggers can specify conditions based on one or more data attributes. 

20 These attributes include data operand values, data locations (including memory 

locations and register IDs), and the like. When one of these attributes is used alone, 
it is an atomic trigger. For example, if a trigger specifies a data operand value, the 
trigger is satisfied when the data operand value is encountered in the program, and 
the h-flow code specified in the target of the corresponding record is triggered as a 

25 result. Vector combinations ofdata attributes can also be used as triggers. For 
example, in an embodiment where a vector combination ofdata location and data 
operand value is used as a trigger, the trigger is satisfied when the data operand value 
and the data location are satisfied at once. This can occur when a "load" instruction 
loads the data operand value from the data location. 
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Typically, data operand values are available later in the pipeline process than 
instruction related values described above. For example, data operand values are 
usually available during execution, whereas instruction related information is usually 
available shortly after fetching. 
5 One example use of a data operand as an atomic trigger is the register address 

of a register dedicated as the stack pointer. It may be beneficial to perform more 
checking when the data operand represents a stack pointer, than when the data 
operand represents any other register. When a stack pointer register is used as a data 
operand, an h-flow code sequence that checks the vaUdity of the stack pointer can be 

10 triggered. This can add any level of checking using h-flow code. This is logically 
equivalent to built-in-self-test (BIST), but unlike traditional BIST that is hardwired 
during chip fabrication, h-flow enabled BIST allows more flexibility. H-flow 
enabled BIST provides the ability to circumvent known bad circuitry by emulating 
missing functionality or rerouting access around damaged resources. This is an 

1 5 example of microarchitectural level resource virtualization. 

If the value in the stack pointer register is within a range expected to be a 
vaUd stack in a user program, more extensive checking may be employed. When the 
stack pointer represents the operating system kernel stack pointer, the context has 
switched from a user program to the kernel, and less checking may be needed. In 

20 general, any type of h-flow code sequence can be applied. 

As previously described, any vector combination of atomic values can be 
utilized as a trigger in conjugate mapping table 200. Vector triggers can include 
instruction attributes, data attributes, or any other attributes in any combination. For 
example, when an instruction operand and a data operand value are combined as a 

25 vector trigger, an h-flow code sequence can be triggered when a particular data 

operand value is associated with a particular instruction operand. This allows an h- 
flow code sequence to be associated with particular runtime contexts, such as when 
the instruction operand is a stack pointer register, and the data operand value is a 
stack pointer value associated with a particular context. 
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H-flow code sequences can also be utilized to fetch into cache those 
instructions that are expected to be used by the main pipeline. When h-flow code 
prefetches instructions into cache, the fetching operation of the main pipeline can be 
much quicker. For example, when a user program calls a function in a dynamic link 
5 library (DLL), such as the *'putc" function which prints a character in the "C" 
language, instructions associated with the function being called are resident in the 
DLL. An atomic or vector trigger can be built that represents an instruction prior to 
the DLL call, and can be used as a trigger for an h-flow code sequence that begins to 
fetch the instructions so that they are within cache when needed by the main pipeline. 
10 A data location trigger can be utilized to trigger h-flow code sequences based 

on the location of a data value. For example, if a data value is resident within a 
protected area of memory, an h-flow code sequence can be triggered that verifies 
access privileges of the user executing the code in the main pipeline. This enables 
access sandboxing. 

15 An h-flow code sequence can also be used for error detection and correction 

in specific areas of on-chip memory. For example, if one or more cache locations is 
known to be unreliable or defective, an atomic trigger or a vector trigger can be built 
that represents an access to the unreliable cache location and an h-flow code 
sequence that performs error detection and correction can be employed. In these 

20 embodiments, the effective yield of the integrated circuit can be increased because 
the faulty cache locations can be made to function correctly. Effectively, the 
conjugate flow hardware and h-flow code become error-tolerating parity resources 
for the main pipeline. 

25 State Triggers 

State triggers can specify conditions based on one or more state attributes. 
These attributes include architectural and microarchitectural states. Examples 
include state information held in reuse buffers, branch target tables, and other 
microarchitectural structures that support speculation. State attributes can be 

30 combined with instruction attributes and data attributes to create hybrid vector 
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triggers. When the hybrid vector trigger is satisfied, the corresponding h-flow code 
is triggered. 

Event Triggers 

5 Triggers within conjugate mapping table 200 can also include event 

attributes. Examples of events are interrupts, exceptions, and the like. In some 
embodiments, events are fully specified using vector combinations of atomic 
instruiction triggers and atomic data triggers. In this manner, h-flow code sequences 
can be utilized in place of interrupt routines and exception handlers, or can be 

1 0 utilized as epilogs and prologs of interrupt routines and exception handlers. Another 
example of an event usable as a trigger in conjugate mapping table 200 is a processor 
state register. In some embodiments, processor state registers include bits or values 
that represent interrupts and exceptions. When these bits or values are changed, 
interrupts or exceptions occur. When one of these interrupts or exceptions is to be 

1 5 used as an event trigger, the processor state register can be used as an event trigger. 

Triggers can also be specified by otherwise unused portions of instruction 
opcodes or instructions words. For example, in a processor having a 64 bit 
instruction field with six unused bits, the six unused bits can be utilized as an 
conjugate mapping trigger. These otherwise unused bits can be used alone as an 

20 atomic trigger or can be used in combination with other atomic values to generate a 
vector trigger. 

Instruction Set Virtualization 
"Instruction set virtualization" refers to an example use of conjugate 
25 processor 100 (Figure 1). This discussion of virtualization is set apart fi-om other 
discussions of sample uses in part because code that executes on h-flow pipelme 120 
in an embodiment supporting virtualization can be thought of as not strictly non- 
essential. In some embodiments, the implemented architecture is a subset of the 
reference architecture, and virtualization can support the emulation of the reference 
30 architecture on the implemented architecture. 
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In general, example uses of h-flow described thus far are hint calculus uses. 
When used for hint calculus, h-flow code includes purely non-essential code that 
only provides hints to affect execution of essential code on the main pipeHne. If h- 
flow is purely non-essential, then even if the h-flow is wrong, the essential code will 
5 still provide the correct result. For example, if non-essential h-flow code is designed 
to prefetch instructions on a predicted path, but the prediction is wrong, the h-flow 
will be wrong, but the correct essential instructions will eventually execute on the 
main pipeline, and the correct logical result will be obtained. 

In some embodiments, the architecture of conjugate processor 100 (Figure 1) 

10 is used to execute code on h-flow pipeline that is not strictly non-essential, but is 
nonetheless still invisible to the programmer. One such example use is virtualization 
of portions of a user program. VirtuaUzation can be accomplished at varying levels 
of abstraction. For example, a single machine instruction can be virtualized using an 
opcode as a trigger. When the opcode is encountered, the trigger is satisfied, and an 

15 h-flow code sequence is executed in the h-flow pipeline. The instruction is 
"virtualized" because the h-flow code sequence is meant to take its place. The 
results of the h-flow execution can replace the results of the instruction being 
virtualized. 

The method and apparatus of the present invention provide a triggering 
20 mechanism and closely coupled hidden microarchitecture pipeline to enable 
virtualization without affecting the main pipeUne computation. In other words, 
instruction set virtualization is achieved without change to the original code in the 
main pipeline. 

Instruction level virtualization can allow a non-native opcode to be 
25 implemented on the processor, or an existing opcode can be mapped to a different 
function. For example, an opcode that is not defined in the instruction set of the 
processor can be implemented in h-flow code. The opcode is specified as an atomic 
trigger, and when the opcode is encountered in the main pipeline, the trigger is 
satisfied and instead of passing the opcode into the pipeline, the h-flow code 
30 sequence executes on the h-flow pipeline. In some embodiments this can be usefiil 
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when software compiled for a later generation of processors is executed on an earlier 
generation that does not have the opcode defined. Forward compatibility can be 
provided for instructions implemented in the later generation of processors. In this 
manner, older processors can be dynamically upgraded such that they can execute 

5 executable files that include processor instructions only defined in a newer 

generation of processor. This is an example of instruction semantic virtualization 
that implements forward compatibility. 

Forward compatibility can also be implemented using event triggers. For 
example, if an unrecognized opcode is encountered, an exception will be generated. 

10 The exception can be specified in conjugate mapping table as an event trigger, and an 
h-flow routine that executes the otherwise unknown opcode can be the target. 

Instruction virtualization can also occur at a higher level. Conjugate mapping 
table 200 can re-map not just individual instructions, but also blocks of instructions 
into h-flow code, A group of instructions or an entire function or subroutine can be 

1 5 replaced with h-flow code when an instruction pointer is used as an atomic trigger in 
conjugate mapping table 200. For example, an instruction pointer trigger can 
correspond to the first location in an integer divide routine. If, after the original 
integer divide routine is implemented, a faster algorithm becomes available in h- 
flow, the integer divide routine can be effectively replaced with h-flow using an 

20 instruction pointer value as a trigger. 

In many processors, inter-instruction communication is accomplished using 
architectural states. That is, one instruction modifies architectural states, and the 
next instruction begins operation with architectural states left by the last instruction. 
When h-flow code virtualizes an instruction, architectural states are modified, and 

25 the next instruction uses the same inter-instruction mechanism for communications 
and the result is the same. Data states and control states can be updated. Data states 
include registers, and control states include next IP, BTB contents, and other 
microarchitectural states. The main pipeline then continues with the new IP. 

Any suitable atomic value or vector can be used to trigger virtualization. For 

30 example, an opcode can be an atomic trigger used to virtualize every occurrence of a 
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specific instruction, or an opcode can be combined with a location to virtualize a 
specific occurrence of an instruction. 

Figure 3 is a diagram showing the generation of a runtime binary with h-flow. 
Figure 3 shows static binary 3 1 0 representing a user program being combined with 
5 runtime library 320 at runtime to create runtime binary 330. Figure 3 is shown with 
one runtime library and one static binary; however, any number of runtime libraries 
can be included while still practicing the present invention. 

As shown in Figure 3, static binary 310 with h-flow includes essential portion 
312 and non-essential portion 314. Essential portion 312 of static binary 310 is 

10 generated from source code 302 by compiler and linker 304. Compiler and linker 
304 interoperate with profiler and profiled data 306 to generate non-essential portion 
314 of static binary 310. Non-essential portion 314 of static binary 310 includes a 
.hint section and a ,hint,2.text section. The .hint section includes h-flow code that 
provides hints for the execution of the .text section in essential portion 312 of static 

15 binary 310, The .hint.2.text section includes conjugate mappings that trigger h-flow 
code sequences within the .hint section. 

In general, any compiled object, such as static binary 310 or runtime library 
320, can be generated having an essential portion and a non-essential portion, but this 
is not necessary. For example, a static binary may include a non-essential portion, 

20 and a runtime library may only include an essential portion. Also, a runtime library 
may include a non-essential portion and not include an essential portion. In this case, 
the runtime library does not provide software to be linked with the static binary, but 
instead includes h-flow code to be linked with the non-essential portion of the static 
binary. 

25 Non-essential portion 3 14 of static binary 3 10 is shown in Figure 3 as having 

been generated at compile time. This is in contrast to other methods previously 
described for generating h-flow. For example, dynamic code analysis block 124 
(Figure 1) generates h-flow code and conjugate mappings adaptively. In some 
embodiments, statically created non-essential code sections, such as non essential 

30 portion 3 14 of static binary 310, are "defaulf non-essential portions that are replaced 
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or augmented by adaptively created non-essential portions. For example, at runtime, 
dynamic code analysis block 124 (Figure 1) can modify or replace h-flow code and 
conjugate mappings. The modified (or new) conjugate mappings and h-flow code 
can be written out as new .hint,2.text and .hint sections respectively. In this manner, 

5 statically created non-essential portions of programs can be replaced or dynamically 
modified over time. 

The .hint and .hint.2.text sections are not necessary. For example, if static 
binary 310 is produced by a compiler without profile information, the .hint and 
.hint.2.text sections may not be created. In other embodiments, when profile 

1 0 information is not available at compile time, default .hint and .hint.2.text sections are 
included within the static binary. 

Runtime library 320 with h-flow includes essential portion 322 and non- 
essential portion 324, Essential portion 312 of static binary 310 and essential portion 
322 of runtime binary 320 are combined at runtime by loader 340 to create essential 

15 portion 332 of runtime binary 330. Likewise, non-essential portion 314 of static 
binary 310 and non-essential portion 324 of runtime library 320 are combined at 
runtime by hint loader 350 to create non-essential portion 334. 

In some embodiments, runtime libraries do not exist, and runtime binary 330 
does not include any information firom runtime libraries. In other embodiments, 

20 multiple runtime libraries exist and runtime binary 330 includes information from the 
static binary and the multiple runtime libraries. 

At load time, loader 340 combines the essential sections firom the different 
binaries and produces the essential portion of the runtime binary. The .text sections 
are combined such that programs within each can interoperate. The .data sections are 

25 combined such that the data space for each is available at runtime. Also at load time, 
hint loader 350 combines the non-essential portions of the different binaries and 
produces the non-essential portion of the runtime binary. The .hint sections can be 
combined, or one can override the other. For example, the static .hint section can be 
a default hint section. In some embodiments, the operation of hint loader 350 is 

30 hidden from the user. 
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Runtime binary 330 includes essential portion 332 and non-essential portion 
334. Essential portion 332 includes a .text section and a .data section. Essential 
portion 332 can also include other sections such as a .bss section. Non-essential 
portion 334 includes a .hint section and a .hint.2.text section. The .hint section 
5 includes h-flow code, and the .hint.2.text section includes conjugate mapping 
information. When the runtime binary with h-flow is executed, the .text section 
within essential portion 332 runs on a main pipeline that is visible to the instruction 
set architecture, such as main pipeline 106 (Figure 1). The .hint.2.text section within 
non-essential portion 334 is installed in a conjugate mapping table, such as conjugate 
10 mapping table 200 (Figure 1), and the .hint section includes h-flow code sequences 
that run on an h-flow pipeline, such as h-flow pipeline 120 (Figure 1), 

The non-essential code as generated by compiler and linker 304 and profiler 
and profiled data 306 can perform many different purposes as described above with 
reference to Figure 1. For example, the h-flow code can provide architecture specific 
15 hints for the target platform. If a particular generation of processor is targeted, then 
the h-flow code can be generated targeted at that particular processor. Likewise, if a 
different generation of processor is targeted, then the h-flow code can be designed to 
generate hints appropriate for that processor. 

Architecture specific h-flow code allows for common essential code to be 
20 shared across several generations, and even separate architectures, of processors. For 
example, an essential portion of a static binary can be compiled once, and 
"optimizations" can be performed with h-flow at runtime. 

The essential portion 312 of static binary 310 can be a "perpetual version" of 
an optimum essential binary assuming a near perfect microarchitecture (e.g. no 
25 branch misprediction or cache miss). Non-essential portion 314 of static binary 310 
can include microarchitecture specific non-essential code to implement the essential 
code on a specific microarchitecture. The combination of the "perpetual version" of 
the essential code and the microarchitectural specific non-essential code together can 
dynamically approximate the performance of the ideal microarchitecture. 
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Figure 4 shows a processing system. Processing system 400 includes 
processor 420 and memory 430. In some embodiments, processor 420 is a conjugate 
processor such as processor 100 (Figure 1). In some embodiments, processor 400 is 
a processor capable of compiling and loading software such as that shown in Figure 
5 3. Processing system 400 can be a personal computer (PC), server, mainframe, 
handheld device, portable computer, set-top box, or any other system that includes 
software. 

Memory 430 represents an article that includes a machine readable medium. 
For example, memory 430 represents any one or more of the following: a hard disk, a 

10 floppy disk, random access memory (RAM), read only memory (ROM), flash 

memory, CDROM, or any other type of article that includes a medium readable by a 
machine. Memory 430 can store instructions for performing the execution of the 
various method embodiments of the present invention. 

It is to be understood that the above description is intended to be illustrative, 

1 5 and not restrictive. Many other embodiments will be apparent to those of skill in the 
art upon reading and xmderstanding the above description. The scope of the 
invention should, therefore, be determined with reference to the appended claims, 
along with the fiiU scope of equivalents to which such claims are entitled. 
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What is claimed is: 



1 1 . / A processor comprising 

2 y a first pipeline configured to execute essential code; 

3 a second pipeline configured to execute non-essential code; and 

4 a conjugate mapping table configured to specify non-essential code to be 

5 executed by the second pipeline. 




1 2, 



The processor of claim 1 wherein the first pipeline is coupled to a first 



2 instruction cache configured to cache instructions that determine the logical 

3 correctness of a program. 

1 3. The processor of claim 2 wherein the second pipeline is coupled to a second 

2 instruction cache configured to cache instructions that provide hints for the execution 

3 of the instructions that determine the logical correctness of the program. 

1 4. The processor of claim 1 wherein the first pipeline is coupled to registers that 

2 store a microarchitectural state, and wherein the conjugate mapping table is 

3 responsive to the microarchitectural state. 

1 5 . The processor of claim 4 further comprising: 

2 a first instruction cache coupled to the first pipeline; and 

3 a second instruction cache coupled between the conjugate mapping table and 

4 the second pipeline. 

1 6. The processor of claim 1 wherein the conjugate mapping table is responsive 

2 to a trigger, the trigger being mapped within the conjugate mapping table to the non- 

3 essential code. 
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7. The processor of claim 1 wherein the conjugate mapping table comprises a 
plurality of records, each of the plurality of records being configured to map a trigger 
to a non-essential code sequence. 



1 8. The processor of claim 7 wherein the trigger comprises an atomic value, such 

2 that the conjugate mapping table is configured to specify the non-essential code 

3 sequence when the atomic value is satisfied. 

1 9. The processor of claim 7 wherein the trigger comprises a vector value, such 

2 that the conjugate mapping table is configured to specify the non-essential code 

3 sequence when the vector value is satisfied. 

1 1 0 The processor of claim 1 further comprising a microarchitectural structure 

2 coupled between the first pipeline and the second pipeline. 

1 11. The processor of claim 1 0 wherein the microarchitectural structm-e comprises 

2 a register bank. 



4 being configured to execute hint calculus code and to provide execution hints to the 

5 ISA visible path. 

1 13. The processor of claim 1 2 wherein the processor can take on architectural 

2 states and microarchitectural states, the conjugate pipeline being configured to affect 

3 microarchitectural states. 

1 14. The processor of claim 12 wherein the ISA visible path includes a pipeline 

2 configured to execute instructions jfrom a user program. 
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A processor comprising: 

an instruction set architecture (ISA) visible path; and 

a conjugate pipehne coupled to the ISA visible path, the conjugate pipeline 



2 



1 



15, The processor of claim 14 wherein the conjugate pipeline is configured to 
execute hint calculus code that virtualizes instructions from the user program. 



2 



1 




a conjugate mapping table coupled to a first pipeline, the conjugate mapping 
table including entries to map triggers from the first pipeline to hint calculus code 
sequences; and 



1 6/^ A processor comprising: 



3 



4 



5 



a second pipeline to execute the hint calculus code sequences. 



1 1 7. The processor of claim 1 6 further comprising microarchitectural structures 

2 responsive to the second pipeline, the microarchitectural structures being configured 

3 to modify states of the first pipeline. 

1 18. The processor of claim 17 wherein the microarchitectural structures comprise 

2 a branch target buffer. 

1 19. The processor of claim 1 7 wherein the triggers comprise: 

2 instruction attributes; 

3 data attributes; 

4 state attributes; and 

5 event attributes. 

1 20. The processor of claim 16 further comprising: 

2 an instruction cache coupled between the conjugate mapping table and the 

3 second pipeline, the instruction cache being configured to cache the hint calculus 

4 code sequences. 
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1 2 L The processor of claim 1 6 wherein the processor is configured to execute 

2 essential code and non-essential code, and wherein the non-essential code comprises 

3 the hint calculus code sequences. 

1 22. The processor of claim 1 6 wherein the second pipeline is configured to 

2 implement register file expansion for forward compatibility across different 

3 generations of processors, 

1 23 . The processor of claim 1 6 wherein the second pipeline is configured to 

2 implement built-in-self-test. 

1 24. The processor of claim 1 6 wherein the second pipeline is configured to 

2 implement instruction set virtualization. 

1 A computer-implemented method of creating a runtime binary comprising: 

2 combining an essential portion of a static binary with an essential portion of a 

3 runtime library to create an essential portion of the runtime binary; and 

4 creating a non-essential portion of the runtime binary using a non-essential 

5 portion of the static binary. 

1 26. The computer-implemented method of claim 25 wherein creating a non- 

2 essential portion comprises : 

3 combining the non-essential portion of the static binary with a non-essential 

4 portion of the runtime library. 

1 27. The computer-implemented method of claim 26 wherein combining the non- 

2 essential portion comprises: 

3 combining non-essential code from the static binary with non-essential code 

4 from the runtime library; and 
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5 
6 



combining conjugate mapping information from the static binary with 
conjugate mapping information from the runtime binary. 



1 28. An article having a machine readable medium with instructions for 

2 ^performing a method of creating a runtime binary disposed thereon, the method 

3 comprising: 

4 combining an essential portion of a static binary with an essential portion of a 

5 runtime library to create an essential portion of the runtime binary; and 

6 creating a non-essential portion of the runtime bin^ using a non-essential 

7 portion of the static binary. 



1 29. The article of claim 28 wherein creating a non-essential portion comprises: 

2 combining the non-essential portion of the static binary with a non-essential 

3 portion of the runtime library, 

1 30. The article of claim 29 wherein combining the non-essential portion 

2 comprises: 

3 combining non-essential code from the static binary with non-essential code 

4 from the runtime library; and 

5 combining conjugate mapping information from the static binary with 

6 conjugate mapping information from the runtime binary. 
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Abstract of the Disclosure 



A conjugate processor includes an instruction set architecture (ISA) visible 
portion having a main pipeline, and an h-flow portion having an h-flow pipeline. 
5 The binary executed on the conjugate processor includes an essential portion that is 
executed on the main pipeUne and a non-essential portion that is executed on the h- 
flow pipeline. The non-essential portion includes hint calculus that is used to 
provide hints to the main pipeline. The conjugate processor also includes a 
conjugate mapping table that maps triggers to h-flow targets. Triggers can be 
10 instruction attributes^ data attributes, state attributes or event attributes. When a 
trigger is satisfied, the h-flow code specified by the target is executed in the h-flow 



pipeline. 
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Terry, Kathleen R. 


Reg. 


No. 


31,884 
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Tong, Viet V. 


Reg. 
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Mates, Robert E. 


Reg. 
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Reg. 
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I hereby authorize them to act and rely on instructions from and communicate directly with the person/assignee/attomey/ 
finffi)rganization/who/which first sends/sent this case to them and by whom/which I hereby declare that I have consented after full 
dis^fsure to be represented unless/until I instruct Schwegman, Lundberg, Woessner & Kluth, P.A. to the contrary. 

Pleb^ direct all correspondence in this case to Schwegman, Lundberg, Woessner & Kluth, P.A. at the address indicated below: 
00 P.O. Box 2938, Minneapolis, MN 55402 

0 Telephone No. (612)373-6900 

1 ft I hereby declare that all statements made herein of my own knowledge are true and that all statements made on information and 
belief are believed to be true; and further that these statements were made with the knowledge that willful false statements and the like so 
made are punishable by fine or imprisonment, or both, under Section 1001 of Title 18 of the United States Code and that such willful false 
statements may jeopardize the validity of the application or any patent issued thereon. 



Fufl 'Name of joint inventor number 1: Hong Wang 
Citizenship : United States of America 

Po^bffice Address; 39877 Sundale Drive/ 

D #105 

Fremont, CA 9453/ 

Signature: 




Hong Wang 



Residence: Fremont, CA 



Date: 





Full Name of joint inventor number 2 : Ralph Kling 

Citizenship: Germany Residence: Sunnyvale, CA 

Post Office Address: 1422 Bedford Avenue 



Signature: 




X Additional inventors are being named on separately numbered sheets, attached hereto. 
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I hereby declare that all statements made herein of my own knowledge are true and that all statements 
made on information and belief are believed to be true; and further that these statements were made with the 
knowledge that willful false statements and the like so made are punishable by fine or imprisonment, or both, under 
Section 1001 of Title 18 of the United States Code and that such willful false statements may jeopardize the validity 
of the application or any patent issued thereon. 

Full Name of joint inventor number 3 : Yong-Fong T.ee 

Citizenship: United States of America Residence: San Jose, CA 

Post Office Address: 7265 Sleepy Creek Dr. 

San Jose, CA 95120 

Signature: ^"^-^ J ""^-.-.^-^-^ Date: ^'"^VS^Iv^ 

Yong-Fong Lee 



Full Name of joint inventor number 4 : David A. Berson 
Citizenship : United States of America 

Post Office Address: 2327 Arabian Drive 

Marietta, GA 30062 



Residence: Marietta, GA 



Sigp^ture: 



David A. Berson 



Date: 



FulFName of joint inventor number 5 : Michael A. Kozuch 
CitSinship: United States of America 

PosM)ffice Address: 1 3535 SW Chariot Court 

m Beaverton, OR 97008 



Residence: Beaverton, OR 



Signature: 



Michael A. Kozuch 



Date: 



Fulttame of joint inventor number 6 : Konrad T.ai 
Citiggnship: United States of America 

Posfri)ffice Address: 520 SE Columbia River Drive 

O #226 

Vancouver, WA 98661 



Residence: Vancouver, WA 



Signature: 



Konrad Lai 



Date: 
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§ 1.56 Duty to disclose information material to patentability. 

(a) A patent by its very nature is affected with a public interest. The public interest is best served, and the most effective patent 
examination occurs when, at the time an application is being examined, the Office is aware of and evaluates the teachings of all information 
material to patentability. Each individual associated with the filing and prosecution of a patent apphcation has a duty of candor and good 
faith in dealing with the Office, which includes a duty to disclose to the Office all information known to that individual to be material to 
patentability as defined in this section. The duty to disclose information exists with respect to each pending claim until the claim is canceled 
or withdrawn from consideration, or the apphcation becomes abandoned. Information material to the patentability of a claim that is 
canceled or withdrawn from consideration need not be submitted if the information is not material to the patentability of any claim 
remaining under consideration in the application. There is no duty to submit information which is not material to the patentability of any 
existing claim. The duty to disclose all information known to be material to patentability is deemed to be satisfied if all information known 
to be material to patentability of any claim issued in a patent was cited by the Office or submitted to the Office in the manner prescribed by 
§§ 1 .97(b)-(d) and 1 .98. However, no patent will be granted on an application in connection with which fraud on the Office was practiced 
or attempted or the duty of disclosure was violated through bad faith or intentional misconduct. The Office encourages apphcants to 
carefully examine: 

(1) prior art cited in search reports of a foreign patent office in a counterpart application, and 

(2) the closest information over which individuals associated with the filmg or prosecution of a patent application believe any 
pending claim patentably defines, to make sure that any material information contained therein is disclosed to the Office. 

("Q Under this section, information is material to patentability when it is not cumulative to information aheady of record or being 
ma^ of record in the apphcation, and 



zf (1) It establishes, by itself or in combination with other information, a prima facie case of unpatentability of a claim; or 

(2) It refutes, or is inconsistent with, a position the applicant takes in: 

Iri (i) Opposing an argument of unpatentability relied on by the Office, or 

(ii) Asserting an argument of patentability. 

A pmrm facie case of unpatentability is estabUshed when the information compels a conclusion that a claim is unpatentable under the 
P^^S^^^^^^^^ of evidence, burden-of-proof standard, givmg each term in the claim its broadest reasonable construction consistent with the 
^P^^?^^^^^^' before any consideration is given to evidence which may be submitted in an attempt to estabhsh a contrary conclusion of 
patSability. 

(c) Individuals associated with the filing or prosecution of a patent application withm the meaning of tiiis section are: 

( 1 ) Each inventor named in the application: 

(2) Each attorney or agent who prepares or prosecutes the application; and 

(3) Every other person who is substantively involved in the preparation or prosecution of the application and who is 
associated with the mventor, with the assignee or with anyone to whom there is an obhgation to assign the apphcation. 

(d) Individuals other than the attorney, agent or inventor may comply with this section by disclosing information to the attomey, 
agent, or inventor. 



Attorney Docket No 884 225US1 

SCHWEGMAN, LUNDBERG, WOESSNER & KLUTH, P.A. 

United States Patent Application 

COMBINED DECLARATION AND POWER OF ATTORNEY 

As a below named inventor I hereby declare that: my residence, post office address and citizenship are as 
stated below next to my name; that 

I verily believe I am the original, first and joint inventor of the subject matter which is claimed and for which 
a patent is sought on the invention entitled: CONJUGATE FLOW PROCESSOR 

The specification of which is attached hereto. 

I hereby state that I have reviewed and understand the contents of the above-identified specification, 
including the claims, as amended by any amendment referred to above. 

I acknowledge the duty to disclose information which is material to the patentabihty of this apphcation in 
accordance with 37 C.F.R. § 1.56 (attached hereto). I also acknowledge my duty to disclose all information known 
to be material to patentability which became available between a filing date of a prior apphcation and the national or 
PCT international filing date in the event this is a Continuation-In-Part apphcation in accordance with 37 C F R 
§l#(e). 

U1 I hereby claim foreign priority benefits under 35 U.S.C. §1 19(a)-(d) or 365(b) of any foreign apphcation(s) 
fo£|atent or inventor's certificate, or 365(a) of any PCT international apphcation which designated at least one 
coQitry other than the United States of America, listed below and have also identified below any foreign application 
for jlatent or inventor's certificate having a filing date before that of the application on the basis of which priority is 
cldfAied: 

Nq such claim for priority is being made at this time. 

ill I hereby claim the benefit under 35 U.S.C. § 1 19(e) of any United States provisional apphcafion(s) Usted 
befev: 



N(|:|uch claim for priority is being made at this time. 

I hereby claim the benefit under 35 U.S.C. § 120 or 365(c) of any United States and PCT international 
application(s) hsted below and, insofar as the subject matter of each of the claims of this application is not disclosed 
in the prior United States or PCT intemational apphcation in the manner provided by the first paragraph of 35 U.S.C. 
§ 1 12, 1 acknowledge the duty to disclose material information as defined in 37 C.F.R. § 1.56(a) which became 
available between the filing date of the prior application and the national or PCT intemational filing date of this 
apphcation: 



No such claim for priority is being made at this time. 
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I hereby appoint the following attomey(s) and/or patent agent(s) to prosecute this application and to transact 
all business in the Patent and Trademark Office connected herewith: 
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Nielsen, Walter W. 
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Black, David W. 


Reg. 
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42,331 


Kaufinartn, John D. 
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No. 24,017 


Oh Allen T 
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Brennan, Leoniede M. 
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No. 


35,832 


Klima-Silberg, Catherine L 


Reg. 
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Padys, Danny J. 


Reg. 


No. 


35^635 


Brennan, Thomas F. 


Reg. 


No. 


35,075 


Kluth, Daniel J. 


Reg. 


No. 32,146 


Parker, J. Kevin 


Reg. 


No 


33,024 


Brooks, Edward J., Ill 


Reg. 


No 


40,925 


Lacy, Rodney L 
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Perdok, Monique M 


Reg. 


No 


42,989 


Chu, Dinh CP. 


Reg. 


No. 
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Lemaire, Charles A 


Reg 


No 36,198 


Prout, William F. 
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Clark, Barbara J. 
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Drake, Eduardo E. 
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Smith, Michael G. 
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Eliseeva, Maria M. 


Reg. 


No. 
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Mack, Lisa K. 
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Speier, Gary J 
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Embretson, Janet E 
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Maeyaert, Paul L 


Reg. 


No. 40,076 


Steffey, Charles E. 
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Fordenbacher, Paul J. 


Reg. 
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Terry, Kathleen R. 
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Forrest, Bradley A. 
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Malen, Peter L. 
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Tong, Viet V. 
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Reg 


No. 


37,748 


Harris, Robert J 
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I hereby authorize them to act and rely on instructions from and communicate directly with the person/assignee/attomey/ 
fiq^organization/who/which first sends/sent this case to them and by whom/which I hereby declare that I have consented after full 
diaq^sure to be represented unless/until I instruct Schwegman, Lundberg, Woessner & Kluth, P. A. to the contrary. 

Pldfle direct all correspondence in this case to Schwegman, Lundberg, Woessner & Kluth, P.A. at the address indicated below: 
Go P.O. Box 2938, Minneapolis, MN 55402 

f 1 Telephone No. (61 2)373-6900 



I I hereby declare that all statements made herein of my own knowledge are true and that all statements made on information and 
befiyf are believed to be true; and further that these statements were made with the knowledge that willful false statements and the like so 
mad^ are punishable by fme or imprisonment, or both, under Section 1001 of Title 18 of the United States Code and that such willful false 
stafepients may jeopardize the validity of the apphcation or any patent issued thereon. 

FuUKameofjoint inventor number 1: Hong Wang 

Cifizfenship: United States of America Residence: Fremont, CA 

PoglOffice Address: 39877 Sundale Drive 

□ Fremont, CA 94538 

Signature: Date: 

Hong Wang 



Full Name of joint inventor number 2 : Ralph Kling 

Citizenship: Germany Residence: Sunnyvale, CA 

Post Office Address: 1422 Bedford Avenue 

Sunnyvale, CA 94087 

Signature: Date: 

Ralph Kling 



X Additional inventors are being named on separately numbered sheets, attached hereto. 
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I hereby declare that all statements made herein of my own knowledge are true and that all statements 
made on information and belief are beheved to be true; and further that these statements were made with the 
knowledge that willful false statements and the like so made are punishable by fme or imprisonment, or both, under 
Section 1001 of Title 1 8 of the United States Code and that such willful false statements may jeopardize the vahdity 
of the application or any patent issued thereon. 

Full Name of joint inventor number 3 : Yong-Fong T.ee 

Citizenship: United States of America Residence: San Jose, CA 

Post Office Address: 7265 Sleepy Creek Dr. 

San Jose, CA 95120 

Signature: . D^te: 

Yong-Fong Lee 



Full Name of joint inventor number 4 : David A. Bersnn 

Citizenship: United States of America Residence: Marietta, GA 

Post Office Address : 2327 Arabian Drive 

^1 Marietta, GA 30062 

Si§Wtoe: ^P^f ^/-^X-,^ Date: 

David A. Berson 7 



Fuf||s[ame of joint inventor number 5 : Michael A. Kozuch 

CitSbnship: United States of America Residence: Beaverton, OR 

Pogtpffice Address: 13535 SW Chariot Court 

yi Beaverton, OR 97008 

Si^pture: Date: 

Michael A. Kozuch 



FulKf^ame of joint inventor number 6 : Konrad Lai 

Citignship : United States of America Residence: Vancouver, WA 

Po&bffice Address: 520 SE Columbia River Drive 

D #226 

Vancouver, WA 98661 

Signature: Date: 

Konrad Lai 
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§ 1.56 Duty to disclose information material to patentability. 

(a) A patent by its very nature is affected with a public interest. The public interest is best served, and the most effective patent 
examination occurs when, at the time an application is being examined, the Office is aware of and evaluates the teachings of all information 
material to patentability. Each individual associated with the filing and prosecution of a patent appUcation has a duty of candor and good 
faith in dealing with the Office, which includes a duty to disclose to the Office all information known to that individual to be material to 
patentability as defined in this section. The duty to disclose information exists with respect to each pending claim until the claim is canceled 
or withdrawn from consideration, or the application becomes abandoned. Information material to the patentability of a claim that is 
canceled or withdrawn from consideration need not be submitted if the information is not material to the patentability of any claim 
remaining under consideration in the application. There is no duty to submit information which is not material to the patentability of any 
existing claim. The duty to disclose all information known to be material to patentability is deemed to be satisfied if all information known 
to be material to patentability of any claim issued in a patent was cited by the Office or submitted to the Office in the manner prescribed by 
§§ 1.97(b)-(d) and 1.98. However, no patent will be granted on an application in connection with which fraud on the Office was practiced 
or attempted or the duty of disclosure was violated through bad faith or intentional misconduct. The Office encourages applicants to 
carefully examine: 

(1) prior art cited in search reports of a foreign patent office in a counterpart application, and 

(2) the closest information over which individuals associated with the filing or prosecution of a patent application believe any 
pending claim patentably defines, to make sure that any material information contained therein is disclosed to the Office. 

fe) Under this section, information is material to patentability when it is not cumulative to information already of record or being 
mapW of record in the application, and 

( 1 ) It estabhshes, by itself or in combination with other information, a prima facie case of unpatentability of a claim; or 

^^:J (2) It refiites, or is inconsistent with, a position the applicant takes in: 

If^ (i) Opposing an argument of unpatentabihty relied on by the Office, or 

L:;, (ii) Asserting an argument of patentability. 

A iMba facie case of unpatentability is established when the information compels a conclusion that a claim is unpatentable under the 
P^^P^^^^^^^^oc of evidence, burden-of-proof standard, giving each term in the claim its broadest reasonable construction consistent with the 
specification, and before any consideration is given to evidence which may be submitted in an attempt to establish a contrary conclusion of 
patffitability. 

(c) Individuals associated with the filing or prosecution of a patent application within the meaning of this section are: 

( 1 ) Each inventor named in the application: 

(2) Each attorney or agent who prepares or prosecutes the application; and 

(3) Every other person who is substantively involved in the preparation or prosecution of the application and who is 
associated with the inventor, with the assignee or with anyone to whom there is an obligation to assign the application. 

(d) Individuals other than the attomey, agent or inventor may comply with this section by disclosing information to the attorney, 
agent, or inventor. 



Attx)mey Docket No 884.225US1 

SCHWEGMAN, LUNDBERG, WOESSNER & KLUTH, P.A. 

United States Patent Application 

COMBINED DECLARATION AND POWER OF ATTORNEY 

As a below named inventor I hereby declare that: my residence, post office address and citizenship are as 
stated below next to my name; that 

I verily believe I am the original, first and joint inventor of the subject matter which is claimed and for which 
a patent is sought on the invention entitled: CONJIIGATR FLOW PROCESSOR . 

The specification of which is attached hereto. 

I hereby state that I have reviewed and understand the contents of the above-identified specification, 
including the claims, as amended by any amendment referred to above. 

I acknowledge the duty to disclose information which is material to the patentability of this appUcation in 
accordance with 37 C.F.R. § 1.56 (attached hereto). I also acknowledge my duty to disclose all information known 
to be material to patentability which became available between a filing date of a prior application and the national or 
PCT international filing date in the event this is a Continuation-In-Part appUcation in accordance with 37 C.F.R. 

Un I hereby claim foreign priority benefits under 35 U.S.C. §1 19(a)-(d) or 365(b) of any foreign application(s) 
foPj)atent or inventor's certificate, or 365(a) of any PCT international application which designated at least one 
ccSitry other than the United States of America, listed below and have also identified below any foreign appUcation 
forjatent or inventor's certificate having a filing date before that of the appUcation on the basis of which priority is 
clfHned: 

No such claim for priority is being made at this time. 

W I hereby claim the benefit under 35 U.S.C. § 1 19(e) of any United States provisional appUcation(s) Usted 
beliiw: 

Npluch claim for priority is being made at this time, 

I hereby claim the benefit under 35 U.S.C. § 120 or 365(c) of any United States and PCT intemational 
application(s) listed below and, insofar as the subject matter of each of the claims of this appUcation is not disclosed 
in the prior United States or PCT intemational application in the manner provided by the first paragraph of 35 U.S.C. 
§ 112 J acknowledge the duty to disclose material information as defined in 37 C.F.R. § 1.56(a) which became 
available between the fiUng date of the prior appUcation and the national or PCT intemational filing date of this 
application: 



No such claim for priority is being made at this time. 
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I hereby appoint the following attomey(s) and/or patent agent(s) to prosecute this appHcation and to transact 
all business in the Patent and Trademark Office connected herewith: 
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Steffey, Charles E. 
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I hereby authorize them to act and rely on instructions from and communicate directly with the person/assignee/attomey/ 
firrp^rganization/who/which first sends/sent this case to them and by whom/which I hereby declare that I have consented after Ml 
disclosure to be represented unless/until I instruct Schwegman, Lundberg, Woessner & Kluth, P.A. to the contrary. 

Pleitb direct all correspondence in this case to Schwegman, Lundberg, Woessner & Kluth, P.A. at the address indicated below: 
Qi P,0. Box 2938, Minneapolis, MN 55402 

D Telephone No. (612)373-6900 



m I hereby declare that all statements made herein of my own knowledge are true and that all statements made on information and 
belfei are believed to be true; and further that these statements were made with the knowledge that willful false statements and the like so 
made' are punishable by fine or imprisonment, or both, under Section 1001 of Title 18 of the United States Code and that such willful false 
statpipents may jeopardize the validity of the application or any patent issued thereon. 

FultPlame of joint inventor number 1 : Hong Wang 

CitfeJnship: United States of America Residence: Fremont, CA 

PostPffice Address: 39877 Sundale Drive 

D #105 

O Fremont, CA 94538 

Signature: Date: 

Hong Wang 



Full Name of joint inventor number 2 : Ralph Kling 

Citizenship: Germany Residence: Sunnyvale, CA 

Post Office Address: 1422 Bedford Avenue 

Sunnyvale, CA 94087 

Signature: Date: 

Ralph Kling 



X Additional inventors are being named on separately numbered sheets, attached hereto. 
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I hereby declare that all statements made herein of my own knowledge are true and that all statements 
made on information and belief are believed to be true; and further that these statements were made with the 
knowledge that willful false statements and the like so made are punishable by fine or imprisonment, or both, under 
Section 1001 of Title 18 of the United States Code and that such willful false statements may jeopardize the validity 
of the application or any patent issued thereon. 

Full Name of joint inventor number 3 : Yong-Fong Lee 

Citizenship: United States of America Residence: San Jose, CA 

Post Office Address: 7265 Sleepy Creek Dr. 

San Jose, CA 95120 

Signature: Date: 

Yong-Fong Lee 



Full Name of joint inventor number 4 : David A. Berson 

Citizenship: United States of America Residence: Marietta, GA 

Post Office Address: 2327 Arabian Drive 

Marietta, GA 30062 

Sign^re: Date: 

"7^^ David A. Berson 



FulfSame of joint inventor number 5 : Michael A. Kozuch 

Citife^s^nship: United States of America Residence: Beaverton, OR 

Posf iffice Address: 13535 SW Chariot Court 



Signature: 




FultSame of joint inventor number 6 : Konrad Lai 

Citiiinship: United States of America Residence: Vancouver, WA 

PosfcDffice Address: 520 SE Columbia River Drive 

D #226 

Vancouver, WA 98661 

Signature: Date: 

Konrad Lai 
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Attorney Docket No.: 884,225USI ^ 
CONJUGATE FLOW PROCESSOR 

Filing Date: Even Date Herewith ^ 

§ 1,56 Duty to disclose information material to patentability. 

(a) A patent by its very nature is affected with a public interest. The public interest is best served, and the most effective patent 
examination occurs when, at the time an application is being examined, the Office is aware of and evaluates the teachings of all information 
material to patentability. Each individual associated with the filing and prosecution of a patent application has a duty of candor and good 
faith in dealing with the Office, which includes a duty to disclose to the Office all information known to that individual to be material to 
patentability as defined in this section. The duty to disclose information exists with respect to each pending claim until the clarni is canceled 
or withdrawn from consideration, or the application becomes abandoned. Information material to the patentability of a claun that is 
canceled or withdrawn from consideration need not be submitted if the information is not material to the patentability of any claim 
remaining under consideration in the application. There is no duty to submit information which is not material to the patentability of any 
existing claim The duty to disclose all information known to be material to patentability is deemed to be satisfied if all mformation known 
to be material to patentability of any claim issued in a patent was cited by the Office or submitted to the Office in the manner prescribed by 
§§ 1 97(b)-(d) and 1.98. However, no patent will be granted on an application in connection with which fraud on the Office was practiced 
or attempted or the duty of disclosure was violated through bad faith or intentional misconduct. The Office encourages applicants to 
carefully examine: 

(1) prior art cited in search reports of a foreign patent office in a counterpart apphcation, and 

(2) the closest information over which individuals associated with the filing or prosecution of a patent application beheve any 
pending claim patentably defmes, to make sure that any material information contained therein is disclosed to the Office. 

(Ii Under this section, information is material to patentability when it is not cumulative to information aheady of record or being 
madei of record in the application, and 

S ( 1 ) It establishes, by itself or in combination with other information, a prima facie case of unpatentability of a claim; or 

(2) It refutes, or is inconsistent with, a position the applicant takes in: 

y1 (i) Opposing an argument of unpatentability reUed on by the Office, or 

Q (ii) Asserting an argument of patentability. 

A prima facie case of unpatentability is established when the information compels a conclusion that a claim is unpatentable under the 
preponderance of evidence, burden-of-proof standard, giving each term in the claim its broadest reasonable construction consistent with the 
spqSffication, and before any consideration is given to evidence which may be submitted in an attempt to establish a contrary conclusion of 
pa®tability. 

(c) Individuals associated with the filing or prosecution of a patent application within the meaning of this section are: 

( 1 ) Each inventor named in the application: 

(2) Each attorney or agent who prepares or prosecutes the application; and 

(3) Every other person who is substantively involved in the preparation or prosecution of the application and who is 
associated with the inventor, with the assignee or with anyone to whom there is an obligation to assign the apphcation. 

(d) Individuals other than the attorney, agent or inventor may comply with this section by disclosing information to the attorney, 
agent, or inventor. 
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Attorney DooJcct No. 884.i25U31 

SCHWEGMAN, LUNDBBRG, WOESSNER. & KLUTH. 

United States Patent Application 

COMBINED DECLaRATTON AND POWER OF ATTORNEY 

As a below namesd inventor IherebjuieclaraJlia^^ as 
stated below next to my name; that 

I verily believe 1 axn the original^ first and joint inventor of the subject matter which is ckimed and for which 
a patent is sought on the invention entitled: CrtWinTGATE FT.OW PROCKSSOtt^ 

The specification of which is attached hereto. 

I hereby state that I have reviewed and understand the contents of the above-identified specification, 
including the claims, as amended by any amendment referred to above, 

I acknowledge the duty to disclose izjformation which is material to the patentability of this application in 
accordance with 37 § 1 .56 (attached hereto). I also acknowledge my duty to disclose all infomiation known 
10 b!?;,inaterial to patentability which became available between a filing date of a prior application and the national or 
PCTI&temaiional filing date in the event this is a Continuaiion-ln-Part application in accordance with 37 C.F,R. 

□ I hereby claim foreign priority benefits nnder 35 US,C. §119(a)-(d) or 365(b) of any foreign application(s) 
for pftent or inventor's certificate, or 365(a) of any PCT international application which designated at least one 
cougiy other than the United States of America, listed below and have also identified below any foreign application 
for ptlml or inventor's certific ate hav ing a filing date before that of the application on the basis of which priority is 
claimed; " 

No.^ch claim for priority is being made at this time, 

□ I hereby claim the benefit under 35 U,S,C. § 1 19(fi) of any United States provisional application(s) listed 
bel®v: 

No such claim for priority is being made at this time* 

I hereby claim the benefit under 35 US-C § 120 or 365(c) of any United States and PCT international 
application(s) listed below and, insofar as the subject matter of each of flie claims of this application is not disclosed 
in the prior United States or PCT international application in the maimer provided by the first paragraph of 35 U.S.C. 
§ 112, 1 acknowledge the duty to disclose material information as defined in 37 C.F.R. § L56(a) which became 
available between the filing date of the prior application and the national or PCT international filing date of this 
application: 

No such claim for priority is being made at this time. 
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AAomiy Dwbrt Wo.! S84.225US1 
CONJUGATE FLOW rROCESSOR 
Tit in K Date: Evert Dlte l-IefgWitl^ 



r hereby appoint the following attomey(s) aiwi/or patent ageat(s) tc prosecute this applicatiop tod to transact 
all business in the Patent and Trademark Office connected herewith: 



SinTTchi, "rimothy E. 

Sreanan,Tlu>waS P. 
Bmob, Edward I., IK 
Chu.DirthC.P. 

DahUohftM. 
Drake, EduArdo E, 
Elisccva, Mafia M. 
EnibrtlSESft, ianct E. 
Fordenbaehcr, P;iul J, 
Forrest, tedley A- 

Harris, E.oben;J. 



Ke5,No. 32,836 
Kefi,Nc. 42,331 

Reg. No, 35,075 
ReS,No. 4Q,MS 

Reg. No, 38 J 07 
Refi. No. 44,639 
R«g. Ne. 40,594 
Reg. Ko. 43.328 

Hftfi. No. 42,546 

Rc^.No.36J43 
Rei;. Ko.37»S46 



Jurfcoviuh, Hwl I Reg* No. 

iiUlifi, ianal M. Reg. No. 

Knufimnn joKn D. Rdg,No, 
Klima-Sllherfi, Cititierinc I. Re|. No. 

Ktuih, Daniel J. Re^.No. 

Uc/, Rodney L. Reg, No. 

tettnlrc, Churles Reg. No. 

tcMome, Dan^ 9. Reg. No* 

UtminiMnrkA. Reg* No. 

LuRdbcre. Steven W, Reg. No. 

MaofciLinJL Reg. No. 

Macy;ieTi, Paul L. Reg. No. 

MattPwrC Reg. No. 

Maleii. Peter L. Rt^.No. 

Ma^cs, Roberi E Reg. No. 

McCraekln, Ann M. Reg. No. 



„Nimi.,Ka3h Reg* No. *4,255 

3 'PJclson, Xlbm r Rig. N0-iW5tr 

37,650 NkteetuWfliltcrW. Rcfi. No. as,539 

24,017 Oh, Alien J. Reg. No. 42,047 

40,052 Padys, Danny J. Reg. >ia. 35.535 

32,14$ Parker, 1 Kevin Reg. No. 33,02^ 

41,136 Perdck, Mowqyift M. R*&. No. 42,0fi{r 

%$,m T?mK,m\\mT. Rfig. No. 33,$55 

40,06t Schumzn. Sheny W. Aeir. No. ^$^2i 

2(5^90 Schwijgman, Micheal L Refi. No. 2S,S Ifi 

30,56S £mit3^.MiehftfilG. Reg. No. 45,366 

42,355 Spcier, Gzri J. Rcg. No. 45,458 

40t076 SwfFby, Charles £. Reg. No. 25,175 

42.S3J 'i'orry, Katlrtecn R. Reg. No. 3 1 

44,S94 Tone, Viet V, Re^^. No. 45,41 6 

35^7i Viksains. Atin Reg, No. 3738 

42,B5S Waessner, Wuffasi D. Rc^, No. 30,440 



I hereby tuthorize tiiem to act a;id rely oa mstructiaps firom and coramunicate directly with tlic p woji/assignca/anomey/ 
fo-n^rganii:arionAvho/which first senda/seat this case to them and by whom/which I tweby declare ihat I hav^; consented aftcx full 
disd&'sure to be represented uolcss/until I instxuci Scbwegmaa, Lttudberg, Wocssc^r & Kluth, P,A. to the contray. 

PIc^ direct all coirespojideucc in this case to Schwcgman, Ltiadbcrg, Wae&m^ & Klutfa, FA. at the address indicated below: 
rf ?-0. Box 2938, MinueapoliSj MN 55402 

^2 Tdephone No. {612)373-6900 



I tor^fry ^^^filare tfaaiall gtetemenis madgt^hsicm of my own taiowledee are tme and that all statcnients made on infonnation and 



bcMcf are believed to be true; andforfiftrfStlE^^ 
ma^ arc punishable by fine or imprisomjfitit, or both, under Section 100 1 of Title 1 8 of the United States Code and that such wiUfiil felse 
sts^pients may jeopardize the validity of the applicadoa or any patent issued thereon. 

FuKNarne of jomr itiventor number 1 : BTftng ^ang 
Cillcnship; United States of America 

Office Address; 39 877 Sundak Drive 

y #105 

Fremont, CA 94538 



Residence: Fremont, CA 



Signature; 



Hottg Wang 



Date: 



Full Naitie of joint mventornumbcr 2: BiilpJtKling 

Citizenship: Geirmany Residence; Sunnyv^ic, CA 

Po5l Office Address: 1 422 Bedford Avenue 

Siamyvale, CA 94087 

Signansrcr . — — — — Date 

Ralph Kling 
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FHifiR Sate: Even D&tc Htfrtwith 

T hereby declare that all Statements made hcreia of my own toiowlcdgc are tru$ and that all statements 
i»dde on inform&cian and belief vift believed (0 be true; sad further that tihese statemcats were niade with the 
knowledge ibat willful false statements and the like so made are pimishitble by fine or inipmoam^nti or both^ under 
SectiQu 1001 of Title 18 of tiie Uniied States Code and that suth willful false statemcnls may jeopojrdke the validity 
of !he application or any patent issued thereon. , 

Full Name of joint inventor number 3 : VyvguyftngLftr 

Cirizen^p: United States of America Residence: San Jose, CA 

Post Office Address: 7265 Sleepy Creek Dr. 

Sail Jose. CA 95120 



SignaiTue; — ^ Date: 

Yoag-Fong Lee 



Full Name of joint iaveator nuiEber 4 : Dayid a. fterchn 

Citizenship: Unitad States of America Resideaee; Marieiui, GA 

?ost Office Address: 2327 Arabian Drive 

Marietta, GA 30062 

Sig^iire: — „ . ^ Date: 

rZ David A. Beraon 



Full ?fenc of joint inventor a^aiber 5 ; Midiael A. Kuwiffh 

Citizenship: United States of Ajmerlca Residence; Beaverton, OR 

PosiSfficc Address: 13535 SW Chariot Couri 

[ff Beaverton, OR 97008 

Sig^afure: . Date; 

Micltael A. Kozuch 



FullJlame of joint inveatOT number 6: 'Kmrs^t^ Tai 

Cit^nship: United States of America Resideuce- Vantouver, WA 

PoCpffice Address: 520 SE Colmnbia River Drive 

■ #226.....: , 

Vancouver, WA 98661 " 

SigBamre: Ce,^ Date; Nacv^ ^^ao 
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A^mty DockcT Net.: 8S4,225US I Pftg* ^ of 4 

conjucjats flow processor 

Piling Date: Svcn Date Herev^^ith 

§ LS6 Du;y to disclose information m^tcrisl to pateutability, 

[a) A patent by ils very nature is affected wiih a public intexesi, Ttic public incerest is bcsi served, aiid tbc mos; effective patcnl 
cxajniaation occurs when, at liie time an application is beifig examined, the Office is aware of and ev^tnates die teachings of all icforajation 
-materia! to paw^tahiiity„Earti m^iivMnai afej£Qp4gv<><^ uritT] t^ff fi^'Xig^43XOg^ga[li!(^^ a duty of coadoraud good 

faith in dealing with (be O^ce, which iiicludes a duty to disclose to the Office all information known to that £divid\iai to~be njateSil lo " 
poientability as defined in this section. The duty to disclose irfonnatioa e?cists wiib respect to each ptetidiag claim until the chim is canceled 
or wiibdratvn from consideration, or tfac application becomes abandoned. Informadon juaicxisd lo t3ie patcnlability of a claim that is 
canceled or withdrawn ftom coaslderatiQii need not be submitted if the infotmatiOn is not material CO the patentability of any claim 
remainiag iMidcT consideraxiou in the application. There is no duty to Aubmit infonnatioii which is not matccial to the patentability of any 
existing claim. The duty to disclose all infonaatton too>wn to be material to paiaaubility is deemed to be satisfied if all infonnation kaomx 
to be jnaterial to patentability of any claim issued in a pawat cited by the Office or submitted to the Office in flxe manner prescribed by 
§1 1 .97(b)-(d) aiid 1.98- However^ no pateni will be gianted on an application in connection with which fraud on Ihe Office was praciiced 
or aiteinpied or the duty of disclosure waa violated through bad feith or inientiOBal misconducc. The Office encourage? applicanis to 
carefully examine: 

{ 1 ) prior art cited in search reports of a foreign patent office in a coxmtcrpari applicatiaiz, and 

(2) the closest infonnalion over which individuals associated Mdx filing or prosecution of a patent application beh'evc any 
O p ending claim parentably defines^ to xn^kc sure ihat any matcxi&l infonnation contained therein iis disclosed to the Office. 

0^ Under this section, infonriaticns is nmterial to patentability when it is not cumulative to information already of record or being 
znac^;|>f record in die application, and 

( 1 ) It establishes, by itself or in combination wiih ofher infonnation* a prima facie case of unpaicntability of a claim; or 

ifl (2) It refutes, or is inconsistca:i± with, a position the applicant takes in: 

— f i)-njipn^i"T.fl| ftTi <iiyi^*w*^^^ftj%Bi«fit^ iik^ nffi<*»j ■ . . 

(ii) Asserting an argumesnt of patentability. 



A )^aa facie case of wpatenrability U established when the information coixipels a conclti^ion that a claim U impatentable under the 
pr^nderance of evidence^ burdfin^-af-pxoof standard, giving each t^m k. the claim its broadest reasonable constniction consistent uith the 
sp«(|tIcatiorL, and before any consideration is given to evidence which may be submitted bx an attempt to est^lijsh a comrary condusioti of 
pa^tabiliiy- 

(c) Individuals associated with the filing or prosecution of a patent ^plication withia the meaning of this section are: 

(1) £ach inventor named in 6ic application: 

(2) Each attorney or a^ent who prepares or prosecutes the application; and 

(3) Every other person who is substantively involved in tbe preparation or prosecution of the application and who is 
associated with tfac inventor, vvith die assignee or with anyone to whom there i$ an obligation to assign the application. 

(d) Individuals other than the attorney^ agcnr or inventor may comply with ihis section by disciosiog informarion to tlie attorney, 
af ontj or Snvemor. 
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